<template>
  <div class="page-header-index-wide">
    <a-row :gutter="24">
      <a-col :sm="24" :md="12" :xl="6" :style="{ marginBottom: '24px' }">
        <chart-card :loading="loading" title="总下载次数" :total="sumDownload">
          <a-tooltip title="指标说明" slot="action">
            <a-icon type="info-circle-o"/>
          </a-tooltip>
          <div>
            <trend flag="up" style="margin-right: 16px;">
              <span slot="term">周同比</span>
              12%
            </trend>
            <trend flag="down">
              <span slot="term">日同比</span>
              11%
            </trend>
          </div>
          <template slot="footer">日均销售额<span>￥ 234.56</span></template>
        </chart-card>
      </a-col>
      <a-col :sm="24" :md="12" :xl="6" :style="{ marginBottom: '24px' }">
        <chart-card :loading="loading" title="近期充值记录" :total="getRechargeNear">
          <a-tooltip title="指标说明" slot="action">
            <a-icon type="info-circle-o"/>
          </a-tooltip>
          <div>
            <mini-area/>
          </div>
          <template slot="footer">日订单量<span> {{ '1234' | NumberFormat }}</span></template>
        </chart-card>
      </a-col>
      <a-col :sm="24" :md="12" :xl="6" :style="{ marginBottom: '24px' }">
        <chart-card :loading="loading" title="支付笔数" :total="6560 | NumberFormat">
          <a-tooltip title="指标说明" slot="action">
            <a-icon type="info-circle-o"/>
          </a-tooltip>
          <div>
            <mini-bar :height="40"/>
          </div>
          <template slot="footer">转化率 <span>60%</span></template>
        </chart-card>
      </a-col>
      <a-col :sm="24" :md="12" :xl="6" :style="{ marginBottom: '24px' }">
        <chart-card :loading="loading" title="运营活动效果" total="78%">
          <a-tooltip title="指标说明" slot="action">
            <a-icon type="info-circle-o"/>
          </a-tooltip>
          <div>
            <mini-progress color="rgb(19, 194, 194)" :target="80" :percentage="78" :height="8"/>
          </div>
          <template slot="footer">
            <trend flag="down" style="margin-right: 16px;">
              <span slot="term">同周比</span>
              12%
            </trend>
            <trend flag="up">
              <span slot="term">日环比</span>
              80%
            </trend>
          </template>
        </chart-card>
      </a-col>
    </a-row>

    <a-card :loading="loading" :bordered="false" :body-style="{padding: '0'}">
      <div class="salesCard">
        <a-tabs default-active-key="1" size="large" :tab-bar-style="{marginBottom: '24px', paddingLeft: '16px'}">
          <div class="extra-wrapper" slot="tabBarExtraContent">
            <div class="extra-item">
              <a>今日</a>
              <a>本周</a>
              <a>本月</a>
              <a>本年</a>
            </div>
            <a-range-picker :style="{width: '256px'}"/>
          </div>
          <a-tab-pane loading="true" tab="销售额" key="1">
            <a-row>
              <a-col :xl="16" :lg="12" :md="12" :sm="24" :xs="24">
                <bar title="销售额排行" :dataSource="uploadCountMonth"/>
              </a-col>
              <a-col :xl="8" :lg="12" :md="12" :sm="24" :xs="24">
                <rank-list title="门店销售排行榜" :list="rankList"/>
              </a-col>
            </a-row>
          </a-tab-pane>
          <a-tab-pane tab="销售趋势" key="2">
            <a-row>
              <a-col :xl="16" :lg="12" :md="12" :sm="24" :xs="24">
                <bar title="销售额趋势" :dataSource="uploadCountMonth"/>
              </a-col>
              <a-col :xl="8" :lg="12" :md="12" :sm="24" :xs="24">
                <rank-list title="门店销售排行榜" :list="rankList"/>
              </a-col>
            </a-row>
          </a-tab-pane>
        </a-tabs>
      </div>
    </a-card>

    <a-row>
      <a-col :span="24">
        <a-card :loading="loading" :bordered="false" title="最近一周访问量统计" :style="{ marginTop: '24px' }">
          <a-row>
            <a-col :span="6">
              <head-info title="今日IP" :content="loginfo.todayIp"></head-info>
            </a-col>
            <a-col :span="2">
              <a-spin class='circle-cust'>
                <a-icon slot="indicator" type="environment" style="font-size: 24px"/>
              </a-spin>
            </a-col>
            <a-col :span="6">
              <head-info title="今日访问" :content="loginfo.todayVisitCount"></head-info>
            </a-col>
            <a-col :span="2">
              <a-spin class='circle-cust'>
                <a-icon slot="indicator" type="team" style="font-size: 24px"/>
              </a-spin>
            </a-col>
            <a-col :span="6">
              <head-info title="总访问量" :content="loginfo.totalVisitCount"></head-info>
            </a-col>
            <a-col :span="2">
              <a-spin class='circle-cust'>
                <a-icon slot="indicator" type="rise" style="font-size: 24px"/>
              </a-spin>
            </a-col>
          </a-row>
          <line-chart-multid :fields="visitFields" :dataSource="visitInfo"></line-chart-multid>
        </a-card>
      </a-col>
    </a-row>
  </div>
</template>

<script>
    import ChartCard from '@/components/ChartCard'
    import ACol from "ant-design-vue/es/grid/Col"
    import ATooltip from "ant-design-vue/es/tooltip/Tooltip"
    import MiniArea from '@/components/chart/MiniArea'
    import MiniBar from '@/components/chart/MiniBar'
    import MiniProgress from '@/components/chart/MiniProgress'
    import RankList from '@/components/chart/RankList'
    import Bar from '@/components/chart/Bar'
    import LineChartMultid from '@/components/chart/LineChartMultid'
    import HeadInfo from '@/components/tools/HeadInfo.vue'

    import Trend from '@/components/Trend'
    import {getLoginfo, getVisitInfo} from '@/api/api'
    import {getAction} from "../../api/manage";

    const rankList = [];
    for (let i = 0; i < 7; i++) {
        rankList.push({
            name: '白鹭岛 ' + (i + 1) + ' 号店',
            total: 1234.56 - i * 100
        })
    }

    const uploadCount = [];
    const uploadCountMonth = [];
    const sumDownload = [];
    const getRechargeNear = 0;
    // for (let i = 0; i < 12; i += 1) {
    //     uploadCountMonth.push({
    //         x: `${i + 1}月`,
    //         y: Math.floor(Math.random() * 1000) + 200
    //     })
    // }
    export default {
        name: "IndexChart",
        components: {
            ATooltip,
            ACol,
            ChartCard,
            MiniArea,
            MiniBar,
            MiniProgress,
            RankList,
            Bar,
            Trend,
            LineChartMultid,
            HeadInfo,
        },
        data() {
            return {
                loading: true,
                center: null,
                uploadCount,
                rankList,
                uploadCountMonth,
                sumDownload,
                getRechargeNear,
                loginfo: {},
                visitFields: ['ip', 'visit'],
                visitInfo: [],
                indicator: <a-icon type="loading" style="font-size: 24px" spin />
        }
        },
        created() {
            setTimeout(() => {
                this.loading = !this.loading
            }, 1000)
            this.initLogInfo();
        },
        methods: {
            initLogInfo() {
                getLoginfo(null).then((res) => {
                    if (res.success) {
                        Object.keys(res.result).forEach(key => {
                            res.result[key] = res.result[key] + ""
                        })
                        this.loginfo = res.result;
                    }
                })
                getVisitInfo().then(res => {
                    if (res.success) {
                        this.visitInfo = res.result;
                    }
                });

                let that = this;
                getAction("/cloud_disk/Index/getUploadCount",{}).then((res)=>{
                    if(res.success){
                        console.log(res)
                        for (let i = 0; i < 12; i += 1) {
                            that.uploadCountMonth.push({
                                x: `${res.result[i].uploadTime}月`,
                                y: res.result[i].uploadCount
                            })
                        }
                        // that.deptNum = res.result[0].nums
                        // var sum=0;
                        // for (let i = 0; i < res.result.length; i++ ) {
                        //     sum += res.result[i].nums
                        // }
                        // that.deptNum = sum
                        // for (let i = 0; i < res.result.length; i++ ) {
                        //     barData.push({
                        //         x: res.result[i].departName,
                        //         y: res.result[i].nums
                        //     })
                        // }
                        // that.$message.success(res.message);
                        // that.$emit('ok');
                    }else{
                        that.$message.warning(res.message);
                    }
                })
                getAction("/cloud_disk/Index/getSumDownload",{}).then((res)=>{
                    if(res.success){
                        console.log(res)
                        that.sumDownload=res.result[0].sumDownload;
                    }else{
                        that.$message.warning(res.message);
                    }
                });
                getAction("/cloud_disk/Index/getRechargeNear",{}).then((res)=>{
                    if(res.success){
                        console.log(res)
                        let tempCount = 0;
                        for(let i = 0 ;i<res.result.length;i++){
                            tempCount = tempCount+i+1;
                        //     that.getRechargeNear=res.result[0].payCountDay;
                        }
                        that.getRechargeNear = tempCount
                    // }else{
                    //     that.$message.warning(res.message);
                    }
                });

            },
        }
    }
</script>

<style lang="less" scoped>
  .circle-cust {
    position: relative;
    top: 28px;
    left: -100%;
  }

  .extra-wrapper {
    line-height: 55px;
    padding-right: 24px;

    .extra-item {
      display: inline-block;
      margin-right: 24px;

      a {
        margin-left: 24px;
      }
    }
  }

  /* 首页访问量统计 */
  .head-info {
    position: relative;
    text-align: left;
    padding: 0 32px 0 0;
    min-width: 125px;

    &.center {
      text-align: center;
      padding: 0 32px;
    }

    span {
      color: rgba(0, 0, 0, .45);
      display: inline-block;
      font-size: .95rem;
      line-height: 42px;
      margin-bottom: 4px;
    }

    p {
      line-height: 42px;
      margin: 0;

      a {
        font-weight: 600;
        font-size: 1rem;
      }
    }
  }
</style>